package it.unipd.dei.bd.icineasti.database;

import it.unipd.dei.bd.icineasti.resource.Sala;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

/**
 * Ritorna una lista delle sale presenti in una sede dato il codiceSede.
 * 
 * @author Bardelle Renzo
 * @version 1.00
 */
public class GetElencoSaleInSedeDatabase {

	/**
	 * Interrogazione al database.
	 */
	private static final String STATEMENT = "SELECT * FROM sala WHERE codicesede=?";
	/**
	 * Connessione al database
	 */
	private final Connection con;
	
	private final int codiceSede;
	
	private final List<Sala> sale;
	
	public GetElencoSaleInSedeDatabase(Connection con, int codiceSede) {
		this.con = con;
		this.codiceSede = codiceSede;
		sale = new ArrayList<Sala>();
	}

	public List<Sala> elencaSale() throws SQLException {

		PreparedStatement pstmt = null;
		ResultSet rs = null;

		try {
			pstmt = con.prepareStatement(STATEMENT);
			pstmt.setInt(1, codiceSede);
			
			rs = pstmt.executeQuery();

			while (rs.next()) {
				sale.add(
							new Sala(
										rs.getString("sigla"),
										rs.getString("nome"), 
										rs.getInt("totalePosti"),
										rs.getInt("codiceSede"),
										rs.getInt("idSala")
									)
						);
			}
		} finally {
			if (rs != null) {
				rs.close();
			}

			if (pstmt != null) {
				pstmt.close();
			}

			con.close();
		}

		return sale;
	}
}
